### WIKIPEDIA

# I<sup>2</sup>C

**I**<sup>2</sup>C (**Inter-Integrated Circuit**), pronounced *I-squared-C*, is a <u>multi-master</u>, <u>multi-slave</u>, <u>packet switched</u>, <u>single-ended</u>, <u>serial computer</u> bus invented by <u>Philips Semiconductor</u> (now <u>NXP Semiconductors</u>). It is typically used for attaching lower-speed peripheral <u>ICs</u> to processors and <u>microcontrollers</u> in short-distance, intra-board communication. Alternatively I<sup>2</sup>C is spelled <u>I2</u>C (pronounced I-two-C) or <u>IIC</u> (pronounced I-I-C).

Since October 10, 2006, no licensing fees are required to implement the I<sup>2</sup>C protocol. However, fees are required to obtain I<sup>2</sup>C slave addresses allocated by NXP.  $^{[1]}$ 

Several competitors, such as Siemens AG (later Infineon Technologies AG, now Intel mobile communications), NEC, Texas Instruments, STMicroelectronics (formerly SGS-Thomson), Motorola (later Freescale, now merged with NXP<sup>[2]</sup>), Nordic Semiconductor and Intersil, have introduced compatible I<sup>2</sup>C products to the market since the mid-1990s.

 $\underline{SMBus}$ , defined by Intel in 1995, is a subset of I<sup>2</sup>C, defining a stricter usage. One purpose of SMBus is to promote robustness and interoperability. Accordingly, modern I<sup>2</sup>C systems incorporate some policies and rules from SMBus, sometimes supporting both I<sup>2</sup>C and SMBus, requiring only minimal reconfiguration either by commanding or output pin use.

### **Contents**

#### 1 Revisions

### 2 Design

- 2.1 Reference design
- 2.2 Message protocols
- 2.3 Messaging example: 24c32 EEPROM
- 2.4 Physical layer
  - 2.4.1 Clock stretching using SCL
  - 2.4.2 Arbitration using SDA
  - 2.4.3 Arbitration in SMBus
  - 2.4.4 Arbitration in PMBus
- 2.5 Differences between modes
- 2.6 Circuit interconnections
- 2.7 Buffering and multiplexing
- 2.8 Line state table
- 2.9 Addressing structure
  - 2.9.1 7-bit addressing
  - 2.9.2 10-bit addressing
- 2.10 Reserved addresses in 7-bit address space
- 2.11 Non-reserved addresses in 7-bit address space
- 2.12 Transaction format
- 2.13 Timing diagram
- 2.14 Example of bit-banging the I<sup>2</sup>C master protocol
- 3 Applications
- 4 Operating-system support
- 5 Development tools
  - 5.1 I2C host adapters
  - 5.2 I<sup>2</sup>C protocol analyzers
  - 5.3 Logic analyzers
- 6 Limitations
- 7 Derivative technologies
- 8 See also
- 9 References
- 10 Further reading
- 11 External links

I<sup>2</sup>C Type Bus **Production history Designer** Philips Semiconductor, known today as NXP Semiconductors Designed 1982 Data Data Open-drain signal Width data line (SDA) + clock line (SCL) 0.1 / 0.4 / 1.0 / 3.4 / **Bitrate** 5.0 Mbit/s (depending on mode) Protocol Serial, half-duplex

### **Revisions**

The history of I<sup>2</sup>C specification releases:

- In 1982, the original 100 kHz I²C system was created as a simple internal bus system for building control electronics with various Philips chips.
- In 1992, Version 1 added 400 kHz Fast-mode (Fm) and a 10-bit addressing mode to increase capacity to 1008 nodes. This was the first standardized version.
- In 1998, Version 2 added 3.4 MHz High-speed mode (Hs) with power-saving requirements for electric voltage and current.
- In 2000, Version 2.1 clarified version 2, without significant functional changes.
- In 2007, Version 3 added 1 MHz Fast-mode plus (Fm+) (using 20 mA drivers), and a device ID mechanism.
- In 2012, Version 4 added 5 MHz *Ultra Fast-mode (UFm)* for new USDA (data) and USCL (clock) lines using <u>push-pull</u> logic without <u>pull-up resistors</u>, and added an assigned manufacturer ID table. It is only a **unidirectional** bus.
- In 2012. Version 5 corrected mistakes
- In 2014, Version 6 corrected two graphs. This is the most recent standard.<sup>[3]</sup>

# Design

I<sup>2</sup>C uses only two bidirectional <u>open-drain</u> lines, Serial Data Line (SDA) and Serial Clock Line (SCL), <u>pulled up</u> with resistors. <sup>[3]</sup> Typical voltages used are +5 V or +3.3 V, although systems with other voltages are permitted.

The I<sup>2</sup>C reference design has a 7-bit or a 10-bit (depending on the device used) address space. <sup>[4]</sup> Common I<sup>2</sup>C bus speeds are the 100 kbit/s standard mode and the 10 kbit/s low-speed mode, but arbitrarily low clock frequencies are also allowed. Recent revisions of I<sup>2</sup>C can host more nodes and run at faster speeds (400 kbit/s Fast mode, 1 Mbit/s Fast mode plus or Fm+, and 3.4 Mbit/s High Speed mode). These speeds are more widely used on embedded systems than on PCs. There are also other features, such as 16-bit addressing.



An example schematic with one master (a microcontroller), three slave nodes (an ADC, a DAC, and a microcontroller), and pull-up resistors  $R_{\text{p}}$ 

Note the bit rates are quoted for the transactions between master and slave without clock stretching or other hardware overhead. Protocol overheads include a slave address and perhaps a register address within the slave

device, as well as per-byte ACK/NACK bits. Thus the actual transfer rate of user data is lower than those peak bit rates alone would imply. For example, if each interaction with a slave inefficiently allows only 1 byte of data to be transferred, the data rate will be less than half the peak bit rate.

The maximal number of nodes is limited by the address space and also by the total bus <u>capacitance</u> of 400 <u>pF</u>, which restricts practical communication distances to a few meters. The relatively high impedance and low noise immunity requires a common ground potential, which again restricts practical use to communication within the same PC board or small system of boards.

### Reference design

The aforementioned reference design is a bus with a <u>clock</u> (SCL) and data (SDA) lines with 7-bit addressing. The bus has two roles for nodes: master and slave:

- Master node node that generates the clock and initiates communication with slaves.
- Slave node node that receives the clock and responds when addressed by the master.

The bus is a <u>multi-master bus</u>, which means that any number of master nodes can be present. Additionally, master and slave roles may be changed between messages (after a STOP is sent).

There may be four potential modes of operation for a given bus device, although most devices only use a single role and its two modes:

- master <u>transmit</u> master node is sending data to a slave,
- master receive master node is receiving data from a slave,
- slave transmit slave node is sending data to the master,
- slave receive slave node is receiving data from the master.

The master is initially in master transmit mode by sending a <u>start bit</u> followed by the 7-bit address of the slave it wishes to communicate with, which is finally followed by a single bit representing whether it wishes to write (0) to or read (1) from the slave.

If the slave exists on the bus then it will respond with an <u>ACK</u> bit (active low for acknowledged) for that address. The master then continues in either transmit or receive mode (according to the read/write bit it sent), and the slave continues in its complementary mode (receive or transmit, respectively).

The address and the data bytes are sent most significant bit first. The start bit is indicated by a high-to-low transition of SDA with SCL high; the stop bit is indicated by a low-to-high transition of SDA with SCL high. All other transitions of SDA take place with SCL low.

If the master wishes to write to the slave, then it repeatedly sends a byte with the slave sending an ACK bit. (In this situation, the master is in master transmit mode, and the slave is in slave receive mode.)

If the master wishes to read from the slave, then it repeatedly receives a byte from the slave, the master sending an ACK bit after every byte except the last one. (In this situation, the master is in master receive mode, and the slave is in slave transmit mode.)

The master then either ends transmission with a <u>stop bit</u>, or it may send another START bit if it wishes to retain control of the bus for another transfer (a "combined message").

### Message protocols

I2C defines basic types of messages, each of which begins with a START and ends with a STOP:

- Single message where a master writes data to a slave.
- Single message where a master reads data from a slave.
- Combined messages, where a master issues at least two reads or writes to one or more slaves.

In a combined message, each read or write begins with a START and the slave address. After the first START in a combined message these are also called *repeated START* bits. Repeated START bits are not preceded by STOP bits, which is how slaves know that the next transfer is part of the same message.

Any given slave will only respond to certain messages, as specified in its product documentation.

Pure I<sup>2</sup>C systems support arbitrary message structures. <u>SMBus</u> is restricted to nine of those structures, such as *read word N* and *write word N*, involving a single slave. <u>PMBus</u> extends SMBus with a *Group* protocol, allowing multiple such SMBus transactions to be sent in one combined message. The terminating STOP indicates when those grouped actions should take effect. For example, one PMBus operation might reconfigure three power supplies (using three different I<sup>2</sup>C slave addresses), and their new configurations would take effect at the same time: when they receive that STOP.

With only a few exceptions, neither I<sup>2</sup>C nor SMBus define message semantics, such as the meaning of data bytes in messages. Message semantics are otherwise product-specific. Those exceptions include messages addressed to the I<sup>2</sup>C *general call* address (0x00) or to the SMBus *Alert Response Address*; and messages involved in the SMBus *Address Resolution Protocol* (ARP) for dynamic address allocation and management.

In practice, most slaves adopt request-response control models, where one or more bytes following a write command are treated as a command or address. Those bytes determine how subsequent written bytes are treated or how the slave responds on subsequent reads. Most SMBus operations involve single-byte commands.

### Messaging example: 24c32 EEPROM

One specific example is the 24c32 type EEPROM, which uses two request bytes that are called Address High and Address Low. (Accordingly, these EEPROMs are not usable by pure SMBus hosts, which only support single-byte commands or addresses.) These bytes are used to address bytes within the 32 kbit (4 kB) supported by that EEPROM; the same two-byte addressing is also used by larger EEPROMs, such as 24c512 ones storing 512 kbits (64 kB). Writing and reading data to these EEPROMs uses a simple protocol: the address is written, and then data is transferred until the end of the message. (That data transfer part of the protocol also makes trouble for SMBus, since the data bytes are not preceded by a count, and more than 32 bytes can be transferred at once. I<sup>2</sup>C EEPROMs smaller than 32 kbit, such as 2 kbit 24c02 ones, are often used on SMBus with inefficient single-byte data transfers.)

A single message writes to the EEPROM. After the START, the master sends the chip's bus address with the direction bit clear (*write*), then sends the two-byte address of data within the EEPROM and then sends data bytes to be written starting at that address, followed by a STOP. When writing multiple bytes, all the bytes must be in the same 32-byte page. While it is busy saving those bytes to memory, the EEPROM will not respond to further I<sup>2</sup>C requests. (That is another incompatibility with SMBus: SMBus devices must always respond to their bus addresses.)

To read starting at a particular address in the EEPROM, a combined message is used. After a START, the master first writes that chip's bus address with the direction bit clear (*write*) and then the two bytes of EEPROM data address. It then sends a (repeated) START and the EEPROM's bus address with the direction bit set (*read*). The EEPROM will then respond with the data bytes beginning at the specified EEPROM data address — a combined message: first a write, then a read. The master issues an ACK after each read byte except the last byte, and then issues a STOP. The EEPROM increments the address after each data byte transferred; multi-byte reads can retrieve the entire contents of the EEPROM using one combined message.

### Physical layer

At the <u>physical layer</u>, both SCL and SDA lines are of <u>open-drain</u> design, thus <u>pull-up resistors</u> are needed. A logic "o" is output by pulling the line to ground, and a logic "1" is output by letting the line float (output <u>high impedance</u>) so that the pull-up resistor pulls it high. A line is never actively driven high. This wire-ANDing allows multiple nodes to connect to the bus without short circuits from signal contention. High-speed systems (and some others) may use a <u>current source</u> instead of a resistor to pull-up on SCL or both SCL and SDA, to accommodate higher bus capacitance and enable faster rise times.

An important consequence of this is that multiple nodes may be driving the lines simultaneously. If *any* node is driving the line low, it will be low. Nodes that are trying to transmit a logical one (i.e. letting the line float high) can detect this and conclude that another node is active at the same time.

When used on SCL, this is called *clock stretching* and used as a flow-control mechanism for slaves. When used on SDA, this is called <u>arbitration</u> and ensures that there is only one transmitter at a time.

When idle, both lines are high. To start a transaction, SDA is pulled low while SCL remains high. Releasing SDA to float high again would be a stop marker, signaling the end of a bus transaction. Although legal, this is typically pointless immediately after a start, so the next step is to pull SCL low.

Except for the start and stop signals, the SDA line only changes while the clock is low; transmitting a data bit consists of pulsing the clock line high while holding the data line steady at the desired level.

While SCL is low, the transmitter (initially the master) sets SDA to the desired value and (after a small delay to let the value propagate) lets SCL float high. The master then waits for SCL to actually go high; this will be delayed by the finite rise time of the SCL signal (the RC time constant of the pull-up resistor and the parasitic capacitance of the bus) and may be additionally delayed by a slave's clock stretching.

Once SCL is high, the master waits a minimum time (4  $\mu$ s for standard-speed I<sup>2</sup>C) to ensure that the receiver has seen the bit, then pulls it low again. This completes transmission of one bit.

After every 8 data bits in one direction, an "acknowledge" bit is transmitted in the other direction. The transmitter and receiver switch roles for one bit, and the original receiver transmits a single "O" bit (ACK) back. If the transmitter sees a "1" bit (NACK) instead, it learns that:

- (If master transmitting to slave) The slave is unable to accept the data. No such slave, command not understood, or unable to accept any more data.
- (If slave transmitting to master) The master wishes the transfer to stop after this data byte.

Only the SDA line changes direction during acknowledge bits; the SCL is always controlled by the master.

After the acknowledge bit, the clock line is low and the master may do one of three things:

- Begin transferring another byte of data: the transmitter set SDA, and the master pulses SCL high.
- Send a "Stop": Set SDA low, let SCL go high, then let SDA go high. This releases the I<sup>2</sup>C bus.
- Send a "Repeated start": Set SDA high, let SCL go high, then pull SDA low again. This starts a new I²C bus transaction without releasing the bus.

#### Clock stretching using SCL

One of the more significant features of the I<sup>2</sup>C protocol is clock stretching. An addressed slave device may hold the clock line (SCL) low after receiving (or sending) a byte, indicating that it is not yet ready to process more data. The master that is communicating with the slave may not finish the transmission of the current bit, but must wait until the clock line actually goes high. If the slave is clock-stretching, the clock line will still be low (because the connections are open-drain). The same is true if a second, slower, master tries to drive the clock at the same time. (If there is more than one master, all but one of them will normally lose arbitration.)

The master must wait until it observes the clock line going high, and an additional minimal time (4 µs for standard 100 kbit/s I<sup>2</sup>C) before pulling the clock low again.

Although the master may also hold the SCL line low for as long as it desires (this is not allowed in newest Rev. 6 of the protocol – subsection 3.1.1), the term "clock stretching" is normally used only when slaves do it. Although in theory any clock pulse may be stretched, generally it is the intervals before or after the acknowledgment bit which are used. For example, if the slave is a microcontroller, its I<sup>2</sup>C interface could stretch the clock after each byte, until the software decides whether to send a positive acknowledgment or a NACK.

Clock stretching is the only time in  $I^2C$  where the slave drives SCL. Many slaves do not need to clock stretch and thus treat SCL as strictly an input with no circuitry to drive it. Some masters, such as those found inside custom  $\underline{ASICs}$  may not support clock stretching; often these devices will be labeled as a "two-wire interface" and not  $I^2C$ .

To ensure a minimal bus  $\underline{\text{throughput}}$ ,  $\underline{\text{SMBus}}$  places limits on how far clocks may be stretched. Hosts and slaves adhering to those limits cannot block access to the bus for more than a short time, which is not a guarantee made by pure I<sup>2</sup>C systems.

#### Arbitration using SDA

Every master monitors the bus for start and stop bits and does not start a message while another master is keeping the bus busy. However, two masters may start transmission at about the same time; in this case, arbitration occurs. Slave transmit mode can also be arbitrated, when a master addresses multiple slaves, but this is less common. In contrast to protocols (such as <a href="Ethernet">Ethernet</a>) that use random back-off delays before issuing a retry, I<sup>2</sup>C has a deterministic arbitration policy. Each transmitter checks the level of the data line (SDA) and compares it with the levels it expects; if they do not match, that transmitter has lost arbitration and drops out of this protocol interaction.

If one transmitter sets SDA to 1 (not driving a signal) and a second transmitter sets it to 0 (pull to ground), the result is that the line is low. The first transmitter then observes that the level of the line is different from that expected and concludes that another node is transmitting. The first node to notice such a difference is the one that loses arbitration: it stops driving SDA. If it is a master, it also stops driving SCL and waits for a STOP; then it may try to reissue its entire message. In the meantime, the other node has not noticed any difference between the expected and actual levels on SDA and therefore continues transmission. It can do so without problems because so far the signal has been exactly as it expected; no other transmitter has disturbed its message.

If the two masters are sending a message to two different slaves, the one sending the lower slave address always "wins" arbitration in the address stage. Since the two masters may send messages to the same slave address, and addresses sometimes refer to multiple slaves, arbitration must continue into the data stages.

Arbitration occurs very rarely, but is necessary for proper multi-master support. As with clock stretching, not all devices support arbitration. Those that do, generally label themselves as supporting "multi-master" communication.

One case which must be handled carefully in multi-master I<sup>2</sup>C implementations is that of the masters talking to each other. One master may lose arbitration to an incoming message, and must change its role from master to slave in time to acknowledge its own address.

In the extremely rare case that two masters simultaneously send identical messages, both will regard the communication as successful, but the slave will only see one message. For this reason, when a slave can be accessed by multiple masters, every command recognized by the slave either must be <u>idempotent</u> or must be guaranteed never to be issued by two masters at the same time. (For example, a command which is issued by only one master need not be idempotent, nor is it necessary for a specific command to be idempotent when some mutual exclusion mechanism ensures that only one master can be caused to issue that command at any given time.)

#### Arbitration in SMBus

While I<sup>2</sup>C only arbitrates between masters, <u>SMBus</u> uses arbitration in three additional contexts, where multiple slaves respond to the master, and one gets its message through.

- Although conceptually a single-master bus, a slave device that supports the "host notify protocol" acts as a master to perform the notification. It seizes the bus and writes a 3-byte message to the reserved "SMBus Host" address (0x08), passing its address and two bytes of data. When two slaves try to notify the host at the same time, one of them will lose arbitration and need to retry.
- An alternative slave notification system uses the separate SMBALERT# signal to request attention. In this case, the host performs a 1-byte read from the reserved "SMBus Alert Response Address" (0x0c), which is a kind of broadcast address. All alerting slaves respond with a data bytes containing their own address. When the slave successfully transmits its own address (winning arbitration against others) it stops raising that interrupt. In both this and the preceding case, arbitration ensures that one slave's message will be received, and the others will know they must retry.
- SMBus also supports an "address resolution protocol", wherein devices return a 16-byte "universal device ID" (UDID). Multiple devices may respond; the one with the lowest UDID will win arbitration and be recognized.

#### **Arbitration in PMBus**

<u>PMBus</u> version 1.3 extends the SMBus alert response protocol in its "zone read" protocol.<sup>[5]</sup> Slaves may be grouped into "zones", and all slaves in a zone may be addressed to respond, with their responses masked (omitting unwanted information), inverted (so wanted information is sent as o bits, which win arbitration), or reordered (so the most significant information is sent first). Arbitration ensures that the highest priority response is the one first returned to the master.

PMBus reserves I2C addresses 0x28 and 0x37 for zone reads and writes, respectively.

### Differences between modes

There are several possible operating modes for I<sup>2</sup>C communication. All are compatible in that the 100 kbit/s standard mode may always be used, but combining devices of different capabilities on the same bus can cause issues, as follows:

- Fast mode is highly compatible and simply tightens several of the timing parameters to achieve 400 kbit/s speed. Fast mode is widely supported by I<sup>2</sup>C slave devices, so a master may use it as long as it knows that the bus capacitance and pull-up strength allow it.
- Fast mode plus achieves up to 1 Mbit/s using more powerful (20 mA) drivers and pull-ups to achieve faster rise and fall times. Compatibility with standard and fast mode devices (with 3 mA pull-down capability) can be achieved if there is some way to reduce the strength of the pull-ups when talking to them
- High speed mode (3.4 Mbit/s) is compatible with normal I<sup>2</sup>C devices on the same bus, but requires the master have an active pull-up on the clock line which is enabled during high speed transfers. The first data bit is transferred with a normal open-drain rising clock edge, which may be stretched. For the remaining seven data bits, and the ack, the master drives the clock high at the appropriate time and the slave may not stretch it. All high-speed transfers are preceded by a single-byte "master code" at fast/standard speed. This code serves three purposes:
  - 1. it tells high-speed slave devices to change to high-speed timing rules,
  - 2. it ensures that fast/normal speed devices will not try to participate in the transfer (because it does not match their address), and
  - 3. because it identifies the master (there are eight master codes, and each master must use a different one), it ensures that arbitration is complete before the high-speed portion of the transfer, and so the high-speed portion need not make allowances for that ability.
- Ultra-Fast mode is essentially a write-only I<sup>2</sup>C subset, which is incompatible with other modes except in that it is easy to add support for it to an existing I<sup>2</sup>C interface hardware design. Only one master is permitted, and it actively drives both clock and data lines at all times to achieve a 5 Mbit/s transfer rate. Clock stretching, arbitration, read transfers, and acknowledgements are all omitted. It is mainly intended for animated <u>LED displays</u> where a transmission error would only cause an inconsequential brief visual glitch. The resemblance to other I<sup>2</sup>C bus modes is limited to:
  - the start and stop conditions are used to delimit transfers,
  - I<sup>2</sup>C addressing allows multiple slave devices to share the bus without SPI bus style slave select signals, and
  - a ninth clock pulse is sent per byte transmitted marking the position of the unused acknowledgement bits.

In all modes, the clock frequency is controlled by the master(s), and a longer-than-normal bus may be operated at a slower-than-nominal speed by underclocking.

### **Circuit interconnections**

I<sup>2</sup>C is popular for interfacing peripheral circuits to prototyping systems, such as the <u>Arduino</u> and <u>Raspberry Pi</u>. I<sup>2</sup>C does not employ a standardized connector, however, and board designers have created various wiring schemes for I<sup>2</sup>C interconnections. To minimize the possible damage due to plugging 0.1-inch headers in backwards, some developers have suggested using alternating signal and power connections of the following wiring schemes: (GND, SCL, VCC, SDA) or (VCC, SDA, GND, SCL).<sup>[6]</sup>

The vast majority of applications use I<sup>2</sup>C in the way it was originally designed -- peripheral ICs directly wired to a processor on the same printed circuit board, and therefore over relatively short distances of less than a foot, without a connector. However a few applications use I<sup>2</sup>C to communicate between two boards, in some cases over a dozen meters apart, using pairs of I<sup>2</sup>C bus buffers to boost the signal or re-encode it as a differential signal traveling over CAT5 or other cable.<sup>[7][8]</sup>

Several standard connectors carry I<sup>2</sup>C signals. For example, the <u>UEXT</u> connector carries I<sup>2</sup>C; the 10-pin iPack connector carries I<sup>2</sup>C;<sup>[9]</sup> the <u>6P6C Lego Mindstorms NXT connector</u> carries I<sup>2</sup>C;<sup>[10][11][12][13]</sup> a few people use the 8p8c connectors and CAT5 cable normally used for Ethernet physical layer to instead carry differential-encoded I<sup>2</sup>C signals<sup>[14]</sup> or boosted single-ended I<sup>2</sup>C signals;<sup>[15]</sup> and every <u>HDMI</u> and most <u>DVI</u> and <u>VGA connectors</u> carry <u>DDC2</u> data over I<sup>2</sup>C.

### **Buffering and multiplexing**

When there are many I<sup>2</sup>C devices in a system, there can be a need to include bus <u>buffers</u> or <u>multiplexers</u> to split large bus segments into smaller ones. This can be necessary to keep the capacitance of a bus segment below the allowable value or to allow multiple devices with the same address to be separated by a multiplexer. Many types of multiplexers and buffers exist and all must take into account the fact that I<sup>2</sup>C lines are specified to be bidirectional. Multiplexers can be implemented with analog switches, which can tie one segment to another. Analog switches maintain the bidirectional nature of the lines but do not isolate the capacitance of one segment from another or provide buffering capability.

Buffers can be used to isolate capacitance on one segment from another and/or allow I<sup>2</sup>C to be sent over longer cables or traces. Buffers for bi-directional lines such as I<sup>2</sup>C must use one of several schemes for preventing latch-up. I<sup>2</sup>C is open-drain, so buffers must drive a low on one side when they see a low on the other. One method for preventing latch-up is for a buffer to have carefully selected input and output levels such that the output level of its driver is higher than its input threshold, preventing it from triggering itself. For example, a buffer may have an input threshold of 0.4 V for detecting a low, but an output low level of 0.5 V. This method requires that all other devices on the bus have thresholds which are compatible and often means that multiple buffers implementing this scheme cannot be put in series with one another.

Alternatively, other types of buffers exist that implement current amplifiers or keep track of the state (i.e. which side drove the bus low) to prevent latch-up. The state method typically means that an unintended pulse is created during a hand-off when one side is driving the bus low, then the other drives it low, then the first side releases (this is common during an I<sup>2</sup>C acknowledgement).

#### Line state table

These tables show the various atomic states and bit operations that may occur during a I2C transaction.

#### Line state

| Туре | Inactive bus              | Start (S)             | ldle<br>(i)          | Stop<br>(P)          | Clock stretching (CS) |
|------|---------------------------|-----------------------|----------------------|----------------------|-----------------------|
| Note | Free to claim arbitration | Bus claiming (master) | Bus claimed (master) | Bus freeing (master) | Paused by slave       |
| SDA  | Passive pullup            | Falling edge (master) | Held low (master)    | Rising edge (master) | Don't care            |
| SCL  | Passive pullup            | Passive pullup        | Passive pullup       | Passive pullup       | Held low (slave)      |

#### Line state

| Туре |                               | e data bit (1) (0)<br>fter SCL to avoid false state | Receiver repl              | ly with ACK bit<br>m sender) | Receiver reply with NACK bit (Byte not received from sender) |                         |  |  |
|------|-------------------------------|-----------------------------------------------------|----------------------------|------------------------------|--------------------------------------------------------------|-------------------------|--|--|
|      | Bit setup (Bs)                | t setup (Bs) Ready to sample (Bx) Bit setup (Bs)    |                            | ACK (A)                      | Bit setup (Bs) NACK (A')                                     |                         |  |  |
| Note | Sender set bit (master/slave) | Receiver sample bit (master/slave)                  | Sender<br>transmitter hi-Z | Sender sees SDA is low       | Sender transmitter hi-Z                                      | Sender sees SDA is high |  |  |
| SDA  | Set bit (after SCL falls)     | Capture bit (after SCL rises)                       | Held low by receive        | er (after SCL falls)         | Driven high (or passive high) by receiver (after SCL falls)  |                         |  |  |
| SCL  | Falling edge (master)         | Rising edge (master)                                | Falling edge<br>(master)   | Rising edge<br>(master)      | Falling edge<br>(master)                                     | Rising edge (master)    |  |  |

### Line state (repeated start)

| Туре | Set                   | Repeated start (Sr) |                      |                      |                          |
|------|-----------------------|---------------------|----------------------|----------------------|--------------------------|
| Note | Start here from ACK   | Avoiding stop       | (P) state            | Start here from NACK | Same as start (S) signal |
| SDA  | Was held low for ACK  | Rising edge         | Passive high         | Passive high         | Falling edge (master)    |
| SCL  | Falling edge (master) | Held low            | Rising edge (master) | Passive high         | Passive pullup           |

## Addressing structure

### 7-bit addressing

| Field:                 | S     | I <sup>2</sup> C address field R/V |   |   |   |     |     |     | R/W'      | Α   | I <sup>2</sup> C transaction sequences | Р    |
|------------------------|-------|------------------------------------|---|---|---|-----|-----|-----|-----------|-----|----------------------------------------|------|
| Туре                   |       |                                    |   |   |   | Byt | e 1 |     |           |     | <b>5</b>                               |      |
| Bit position in byte X |       | 7                                  | 6 | 5 | 4 | 3   | 2   | 1   | 0         |     | Byte X etc  Rest of the read or write  |      |
| 7-bit address pos      | Start | 7                                  | 6 | 5 | 4 | 3   | 2   | 1   |           | ACK |                                        | Stop |
| Nista                  |       | MOD                                |   |   |   |     |     |     | 1 = Read  |     | transactions goes here                 |      |
| Note                   |       | MSB                                |   |   |   |     |     | LSB | 0 = Write | 1   |                                        |      |

### 10-bit addressing

| Field:                 | s     | 10-bit mode indicator |     |   |      |    | Upper<br>addr |   | R/W'         | А   | Lower address field |                   |   |   |                                                  |             |   |     | I2C transaction sequences | Р |  |  |  |  |     |  |  |
|------------------------|-------|-----------------------|-----|---|------|----|---------------|---|--------------|-----|---------------------|-------------------|---|---|--------------------------------------------------|-------------|---|-----|---------------------------|---|--|--|--|--|-----|--|--|
| Туре                   |       |                       |     |   |      | Ву | rte 1         |   | Byte 2       |     |                     |                   |   |   |                                                  |             |   |     |                           |   |  |  |  |  |     |  |  |
| Bit position in byte X |       | 7                     | 6   | 5 | 4    | 3  | 2             | 1 | 0            |     | 7                   | 6                 | 5 | 4 | 3                                                | 2           | 1 | 0   |                           |   |  |  |  |  |     |  |  |
| Bit value              |       | 1                     | 1   | 1 | 1    | 0  | х             | х | х            |     | Х                   | Х                 | X | Х | Х                                                | Х           | х | х   | Byte X etc                |   |  |  |  |  |     |  |  |
| 10-bit address pos     | Start |                       |     |   | 10 9 |    |               |   |              |     | ACK                 | ACK 8 7 6 5 4 3 2 |   | 1 | Rest of the read or write transactions goes here | Stop        |   |     |                           |   |  |  |  |  |     |  |  |
| Nata                   |       |                       |     |   |      |    |               |   |              | Inc | Indicates 10-bit    |                   |   |   |                                                  | 1 =<br>Read |   |     |                           |   |  |  |  |  | LOD |  |  |
| Note                   |       | mo                    | ode |   |      |    | MSB           |   | 0 =<br>Write |     |                     |                   |   |   |                                                  |             |   | LSB |                           |   |  |  |  |  |     |  |  |

### Reserved addresses in 7-bit address space

Two groups of addresses are reserved for special functions:

- 0000 XXX
- 1111 XXX

|                  |                 | 8-bit by | yte       |                                        |  |  |  |
|------------------|-----------------|----------|-----------|----------------------------------------|--|--|--|
| Reserved address | 7-bit a         | ddress   | R/W value | Description                            |  |  |  |
| index            | MSB LSB (4-bit) |          | 1-bit     | _ = ================================== |  |  |  |
| 1                | 0000            | 000      | 0         | General call                           |  |  |  |
| 2                | 0000            | 000      | 1         | Start byte                             |  |  |  |
| 3                | 0000            | 001      | Х         | CBUS address                           |  |  |  |
| 4                | 0000            | 010      | Х         | Reserved for different bus forma       |  |  |  |
| 5                | 0000            | 011      | Х         | Reserved for future purpose            |  |  |  |
| 6                | 0000            | 1XX      | Х         | HS-mode master code                    |  |  |  |
| 7                | 1111            | 1XX      | 1         | Device ID                              |  |  |  |
| 8                | 1111            | 0XX      | Х         | 10-bit slave addressing                |  |  |  |

SMBus reserves some additional addresses. In particular, 0001 000 is reserved for the SMBus host, which may be used by master-capable devices, 0001 100 is the "SMBus alert response address" which is polled by the host after an out-of-band interrupt, and 1100 001 is the default address which is initially used by devices capable of dynamic address assignment.

### Non-reserved addresses in 7-bit address space

| MSB (4-bit) | Typical usage <sup>[16][17][18][19][20]</sup>             |
|-------------|-----------------------------------------------------------|
| 0001        | Digital Receivers, SMBus                                  |
| 0010        | TV Video Line Decoders, IPMB                              |
| 0011        | AV CODECs                                                 |
| 0100        | Video Encoders, GPIO Expanders                            |
| 0101        | ACCESS Bus, PMBus                                         |
| 0110        | VESA DDC, PMBus                                           |
| 0111        | Display Controller                                        |
| 1000        | TV Signal Processing, Audio Processing, SMBus             |
| 1001        | AV Switching, ADCs and DACs, IPMB, SMBus                  |
| 1010        | Storage Memory, Real Time Clock                           |
| 1011        | AV Processors                                             |
| 1100        | PLLs and Tuners, Modulators and Demodulators, SMBus       |
| 1101        | AV Processors and Decoders, Audio Power Amplifiers, SMBus |
| 1110        | AV Colour Space Converters                                |

Although MSB 1111 is reserved for Device ID and 10-bit slave addressing, it is also used by VESA DDC display dependent devices such as pointing devices. [21]

#### Transaction format

- There is a read transaction
- There is a write transaction
- There is a combined read/write transaction format

### **Timing diagram**



- 1. Data transfer is initiated with a start bit (S) signaled by SDA being pulled low while SCL stays high.
- 2. SDA sets the 1st data bit level while keeping SCL low (during blue bar time).
- 3. The data are sampled (received) when SCL rises (green) for the first bit (B1).
- 4. This process repeats, SDA transitioning while SCL is low, and the data being read while SCL is high (B2, Bn).
- 5. A stop bit (P) is signaled when SDA is pulled high while SCL is high.

In order to avoid false marker detection, SDA is changed on the SCL falling edge and is sampled and captured on the rising edge of SCL.

### Example of bit-banging the I<sup>2</sup>C master protocol

Below is an example of <u>bit-banging</u> the I<sup>2</sup>C protocol as an I<sup>2</sup>C master. The example is written in <u>pseudo</u>  $\underline{C}$ . It illustrates all of the I<sup>2</sup>C features described before (clock stretching, arbitration, start/stop bit, ack/nack). [22]

```
1 // Hardware-specific support functions that MUST be customized:
2 #define IZCSPEED 100
3 void IZC_delay(void);
4 bool read_SCL(void); // Return current level of SCL line, 0 or 1
5 bool read_SDA(void); // Return current level of SDA line, 0 or 1
6 void set_SCL(void); // Do not drive SCL (set pin high-impedance)
7 void clear_SCL(void); // Actively drive SCL signal low
8 void set_SDA(void); // Do not drive SDA (set pin high-impedance)
9 void clear_SDA(void); // Actively drive SDA signal low
10 void arbitration_lost(void);
```

```
12 bool started = false; // global data
13
14 void i2c start cond(void) {
15
    if (started) {
       // if started, do a restart condition
// set SDA to 1
16
18
        set_SDA();
19
       I2C_delay();
20
        set_SCL();
       while (read_SCL() == 0) { // Clock stretching
 21
         // You should add timeout to this loop
 22
 23
 24
 25
        // Repeated start setup time, minimum 4.7us
26
       I2C_delay();
 27
28
29
      if (read_SDA() == 0) {
30
       arbitration_lost();
31
 32
33
      // SCL is high, set SDA from 1 to 0.
      clear_SDA();
 34
      I2C_delay();
 36
      clear_SCL();
37
      started = true;
 38 }
39
40 void i2c_stop_cond(void) {
41
      // set SDA to 0
42
      clear SDA();
43
      I2C_delay();
 45
      set_SCL();
      // Clock stretching
46
47
      while (read_SCL() == 0) {
48
       // add timeout to this loop.
49
50
      // Stop bit setup time, minimum 4us
51
 52
      I2C delay();
53
      // SCL is high, set SDA from 0 to 1
54
 55
      set_SDA();
 56
      I2C_delay();
57
 58
     ..cau_sUA() == 0) .
arbitration_lost();
}
      if (read_SDA() == 0) {
59
60
61
62
      started = false;
63 }
65 // Write a bit to I2C bus
 66 void i2c_write_bit(bool bit) {
67
     if (bit) {
68
       set_SDA();
69
     } else {
70
       clear_SDA();
71
 72
      // SDA change propagation delay
74
     I2C_delay();
75
76
      // Set SCL high to indicate a new valid SDA value is available
. 77
      set_SCL();
78
79
      // Wait for SDA value to be read by slave, minimum of 4us for standard mode
80
      I2C delay();
81
      while (read_SCL() == 0) { // Clock stretching
82
83
       // You should add timeout to this loop
84
85
86
      // SCL is high, now data is valid
87
     // If SDA is high, check that nobody else is driving SDA if (bit \&\& (read\_SDA() == 0)) {
88
89
       arbitration_lost();
90
91
92
      // Clear the SCL to low in preparation for next change
      clear_SCL();
94 }
95
96 // Read a bit from I2C bus
97 bool i2c_read_bit(void) {
98
     bool bit:
99
     // Let the slave drive data
100
101
      set_SDA();
102
103
      // Wait for SDA value to be written by slave, minimum of 4us for standard mode
104
1105
106
      // Set SCL high to indicate a new valid SDA value is available
      set_SCL();
107
```

```
1108
109
      while (read_SCL() == 0) { // Clock stretching
110
        // You should add timeout to this loop
111
112
113
      // Wait for SDA value to be written by slave, minimum of 4us for standard mode
114
      I2C_delay();
115
116
      // SCL is high, read out bit
117
      bit = read SDA();
1118
119
      // Set SCL low in preparation for next operation
120
      clear SCL();
122
123 }
124
125 // Write a byte to I2C bus. Return 0 if ack by the slave.
126 bool i2c_write_byte(bool send_start,
127
                         bool send stop,
128
                         unsigned char byte) {
129
      unsigned bit;
130
      bool
               nack;
132
      if (send_start) {
133
       i2c_start_cond();
134
135
      for (bit = 0; bit < 8; ++bit) {</pre>
1136
137
        i2c_write_bit((byte & 0x80) != 0);
138
        bvte <<= 1:
139
140
      nack = i2c_read_bit();
142
143
      if (send_stop) {
144
        i2c_stop_cond();
145
1146
147
      return nack:
148 }
149
150 // Read a byte from I2C bus
151 unsigned char i2c_read_byte(bool nack, bool send_stop) {
152
      unsigned char byte = 0;
153
      unsigned char bit;
154
155
156
      for (bit = 0; bit < 8; ++bit) {
  byte = (byte << 1) | i2c_read_bit();</pre>
157
158
      i2c_write_bit(nack);
160
161
      if (send_stop) {
162
        i2c_stop_cond();
163
164
165
      return byte;
166 }
167
168 void I2C_delay(void) {
      volatile int v;
170
171
172
      for (i = 0; i < I2CSPEED / 2; ++i) {
173
      }
174
175 }
```

# **Applications**

I<sup>2</sup>C is appropriate for peripherals where simplicity and low manufacturing cost are more important than speed. Common applications of the I<sup>2</sup>C bus are:

- Reading configuration data from <u>SPD</u> EEPROMs on <u>SDRAM</u>, <u>DDR SDRAM</u>, <u>DDR2 SDRAM</u> memory sticks (<u>DIMM</u>) and other stacked PC boards
- Supporting systems management for PCI cards, through an SMBus 2.0 connection.
- Accessing NVRAM chips that keep user settings.
- Accessing low-speed DACs and ADCs.
- Changing contrast, hue, and color balance settings in monitors (Display Data Channel).
- · Changing sound volume in intelligent speakers.
- Controlling <u>OLED/LCD</u> displays, like in a cellphone.
- Reading hardware monitors and diagnostic sensors, like a CPU thermistor or fan speed. [23]
- Reading real-time clocks.
- Turning on and turning off the power supply of system components.<sup>[24]</sup>



STMicroelectronics 24C08: Serial EEPROM with I<sup>2</sup>C bus

A particular strength of I<sup>2</sup>C is the capability of a <u>microcontroller</u> to control a network of device chips with just two <u>general-purpose I/O</u> pins and software. Many other bus technologies used in similar applications, such as Serial Peripheral Interface Bus, require more pins and signals to connect devices.

# **Operating-system support**

- In <u>AmigaOS</u> one can use the i2c.resource component<sup>[25]</sup> for AmigaOS 4.x and <u>MorphOS</u> 3.x or the shared library i2c.library by Wilhelm Noeker for older systems.
- Arduino developers can use the "Wire" library.
- Maximite supports I<sup>2</sup>C communications natively as part of its MMBasic.
- PICAXE uses the i2c and hi2c commands.
- eCos supports I<sup>2</sup>C for several hardware architectures.
- ChibiOS/RT supports I<sup>2</sup>C for several hardware architectures.
- FreeBSD, NetBSD and OpenBSD also provide an I<sup>2</sup>C framework, with support for a number of common master controllers and sensors.
- In <u>Linux</u>, I<sup>2</sup>C is handled with a device driver for the specific device, and another for the I<sup>2</sup>C (or <u>SMBus</u>) adapter to which it is connected. Several hundred such drivers are part of current releases.
- In Mac OS X, there are about two dozen I2C kernel extensions that communicate with sensors for reading voltage, current, temperature, motion, and other physical status.
- In Microsoft Windows, I<sup>2</sup>C is implemented by the respective device drivers of much of the industry's available hardware.
- Unison OS, a POSIX RTOS for IoT, supports I<sup>2</sup>C for several MCU and MPU hardware architectures.
- In Windows CE, I<sup>2</sup>C is implemented by the respective device drivers of much of the industry's available hardware.
- In RISC OS, I²C is provided with a generic I²C interface from the IO controller and supported from the OS module system
- In Sinclair QDOS and Minerva QL operating systems I<sup>2</sup>C is supported by a set of extensions provided by TF Services.

# **Development tools**

When developing or troubleshooting systems using I2C, visibility at the level of hardware signals can be important.

### I<sup>2</sup>C host adapters

There are a number of hardware solutions for host computers, running <u>Linux</u>, <u>Mac</u> or <u>Windows</u>, I<sup>2</sup>C master and/or slave capabilities. Most of them are based on USB-to-I<sup>2</sup>C adapters. Not all of them require proprietary drivers or APIs.

#### I<sup>2</sup>C protocol analyzers

I<sup>2</sup>C protocol analyzers are tools that sample an I<sup>2</sup>C bus and decode the electrical signals to provide a higher-level view of the data being transmitted on the

### Logic analyzers

When developing and/or troubleshooting the I<sup>2</sup>C bus, examination of hardware signals can be very important. <u>Logic analyzers</u> are tools that collect, analyze, decode, and store signals, so people can view the high-speed waveforms at their leisure. Logic analyzers display time stamps of each signal level change, which can help find protocol problems. Most logic analyzers have the capability to decode bus signals into high-level protocol data and show ASCII data.

### Limitations

The assignment of slave addresses is one weakness of I<sup>2</sup>C. 7 bits is too few to prevent address collisions between the many thousands of available devices, and manufacturers rarely dedicate enough pins to configure the full slave address used on a given board. 3 pins is typical, giving only 8 choices of slave address. While some devices can set multiple address bits per pin, [<sup>26</sup>][<sup>27</sup>] e.g., by using a spare internal ADC channel to sense one of 8 ranges set by an external voltage divider, usually each pin controls 1 address bit. Manufacturers may provide pins to configure a few low-order bits of the address and arbitrarily set the higher-order bits to some value based on the model. This limits the number of devices of that model that may be present on the same bus to some low number, typically between 2 and 8. That partially addresses the issue of address collisions between different vendors.

10-bit I<sup>2</sup>C addresses are not yet widely used, and many host operating systems do not support them. [28] Neither is the complex SMBus "ARP" scheme for dynamically assigning addresses (other than for PCI cards with SMBus presence, for which it is required).

Automatic bus configuration is a related issue. A given address may be used by a number of different protocol-incompatible devices in various systems, and hardly any device types can be detected at runtime. For example, 0x51 may be used by a 24LCo2 or 24C32 EEPROM, with incompatible addressing; or by a PCF8563 RTC, which cannot reliably be distinguished from either (without changing device state, which might not be allowed). The only reliable configuration mechanisms available to hosts involve out-of-band mechanisms such as tables provided by system firmware, which list the available devices. Again, this issue can partially be addressed by ARP in SMBus systems, especially when vendor and product identifiers are used; but that has not really caught on. The rev. 03 version of the I<sup>2</sup>C specification adds a device ID mechanism.

I<sup>2</sup>C supports a limited range of speeds. Hosts supporting the multi-megabit speeds are rare. Support for the Fm+ 1 Mbit/s speed is more widespread, since its electronics are simple variants of what is used at lower speeds. Many devices do not support the 400 kbit/s speed (in part because SMBus does not yet support it). I<sup>2</sup>C nodes implemented in software (instead of dedicated hardware) may not even support the 100 kbit/s speed; so the whole range defined in the specification is rarely usable. All devices must at least partially support the highest speed used or they may spuriously detect their device address.

Devices are allowed to stretch clock cycles to suit their particular needs, which can starve bandwidth needed by faster devices and increase latencies when talking to other device addresses. Bus capacitance also places a limit on the transfer speed, especially when current sources are not used to decrease signal rise times.

Because I<sup>2</sup>C is a shared bus, there is the potential for any device to have a fault and hang the entire bus. For example, if any device holds the SDA or SCL line low, it prevents the master from sending START or STOP commands to reset the bus. Thus it is common for designs to include a reset signal that provides an external method of resetting the bus devices. However many devices do not have a dedicated reset pin, forcing the designer to put in circuitry to allow devices to be power-cycled if they need to be reset.

Because of these limits (address management, bus configuration, potential faults, speed), few I<sup>2</sup>C bus segments have even a dozen devices. It is common for systems to have several such segments. One might be dedicated to use with high-speed devices, for low-latency power management. Another might be used to control a few devices where latency and throughput are not important issues; yet another segment might be used only to read EEPROM chips describing add-on cards (such as the SPD standard used with DRAM sticks).

# **Derivative technologies**

I<sup>2</sup>C is the basis for the ACCESS.bus, the VESA Display Data Channel (DDC) interface, the System Management Bus (SMBus), Power Management Bus (PMBus) and the Intelligent Platform Management Bus (IPMB, one of the protocols of IPMI). These variants have differences in voltage and clock frequency ranges, and may have interrupt lines.

High-availability systems (AdvancedTCA, MicroTCA) use 2-way redundant I<sup>2</sup>C for shelf management. Multi-master I<sup>2</sup>C capability is a requirement in these systems.

TWI (Two-Wire Interface) or TWSI (Two-Wire Serial Interface) is essentially the same bus implemented on various system-on-chip processors from  $\underline{\text{Atmel}}$  and other vendors. [29] Vendors use the name TWI, even though I<sup>2</sup>C is not a registered trademark. Trademark protection only exists for the respective logo (see upper right corner), and patents on I<sup>2</sup>C have now lapsed.

In some cases, use of the term "two-wire interface" indicates incomplete implementation of the I<sup>2</sup>C specification. Not supporting arbitration or clock stretching is one common limitation, which is still useful for a single master communicating with simple slaves that never stretch the clock.

### See also

- List of network buses
- UEXT Connector
- System Management Bus

### References

- 1. I2C Licensing Information (http://www.nxp.com/documents/application\_note/AN10216.pdf)
- 2. Freescale merger with NXP (http://investors.nxp.com/phoenix.zhtml?c=209114&p=irol-newsArticle&ID=2120581)
- 3. "I2C-bus specification and user manual" (http://www.nxp.com/documents/user\_manual/UM10204.pdf) (PDF). Rev. 6. NXP. 4 April 2014. UM10204.
- 4. 7-bit, 8-bit, and 10-bit I2C Slave Addressing (http://www.totalphase.com/support/kb/10039/)
- 5. Using The ZONE\_READ And ZONE\_WRITE Protocols (http://pmbus.org/Assets/PDFS/Public/PMBus\_AN001\_Rev\_1\_0\_1\_20160107.pdf) (PDF) (Application Note). Revision 1.0.1. System Management Interface Forum. 7 January 2016. AN001.
- 6. Is there any definitive I2C pin-out guidance out there? Not looking for a "STANDARD"; StackExchange (http://electronics.stackexchange.com/a/48343).
- 7. "NXP Application note AN11075: Driving I2C-bus signals over twisted pair cables with PCA9605" (http://www.nxp.com/docs/en/application-note/AN1107 5.pdf)
- 8. Joshua Vasquez. "Taking the leap off board: An introduction to I2C over long wires" (http://hackaday.com/2017/02/08/taking-the-leap-off-board-an-introd uction-to-i2c-over-long-wires/)
- 9. "iPack Stackable Board Format" (http://www.mcc-us.com/ipack1.htm)
- 10. Mario Ferrari; Giulio Ferrari. "Building Robots with LEGO Mindstorms NXT" (https://books.google.com/books?id=1LizU1nKZO0C). p. 63-64
- 11. Michael Gasperi, Philippe Hurbain. "Chapter 13: I<sup>2</sup>C Bus Communication". from <u>"Extreme NXT: Extending the LEGO MINDSTORMS NXT to the Next Level" (https://books.google.com/books?id=vtUPNDYSTssC)</u>. 2010.
- 12. Philo. "NXT connector plug" (http://www.philohome.com/nxtplug/nxtplug.htm)
- 13. Sivan Toledo. "I2C Interfacing Part 1: Adding Digital I/O Ports" (http://www.tau.ac.il/~stoledo/lego/i2c-8574/). 2006.
- 14. "Sending I2C reliabily over Cat5 cables" (https://electronics.stackexchange.com/questions/107663/sending-i2c-reliabily-over-cat5-cables)
- 15. "I2C Bus Connectors & Cables" (https://www.i2cchip.com/i2c\_connector.html)

Philips Semiconductors I2C Address Allocation Table Selection Guide 1999 Aug 24, <a href="http://simplemachines.it/doc/IC12\_97\_I2C\_ALLOCATION.pdf">http://simplemachines.it/doc/IC12\_97\_I2C\_ALLOCATION.pdf</a>
 Retrieved 1 October 2017

- 17. Data Handbook IC12: I2C Peripherals, Philips ordering code 9397 750 00306
- 18. System Management Bus (SMBus) Specification Version 3.0
- 19. VESA Display Data Channel Command Interface (DDC/CI) Standard, Version 1, August 14, 1998
- 20. Intelligent Platform Management Interface Specification Second Generation V2.0 Document Revision 1.1 October 1, 2013, April 21, 2015 E7 Markup
- 21. VESA Display Data Channel Command Interface (DDC/CI) Standard, Version 1, August 14, 1998
- 22. TWI Master Bit Band Driver; Atmel; July 2012 (http://www.atmel.com/Images/doc42010.pdf)
- 23. Speedfan reading computer hardware monitoring chips (http://www.almico.com/speedfan.php) Archived (https://web.archive.org/web/2015081621165 9/http://www.almico.com/speedfan.php) August 16, 2015, at the Wayback Machine.
- 24. "Benefits of Power Supplies Equipped with I2C Ethernet Communications" (http://aegispower.com/index.php/2015-01-15-19-35-10/178-benefits-of-power-supplies-equipped-with-i2c-ethernet-communications). Aegis Power Systems, Inc. Aegis Power Systems, Inc. Retrieved 21 December 2015.
- 25. i2c.resource component (http://www.os4depot.net/?function=showfile&file=driver/misc/i2c.resource.lha) for AmigaOS 4.x.
- 26. Maxim's MAX7314 (http://www.maxim-ic.com/quick\_view2.cfm/qv\_pk/4200) uses a common purely digital low/high/SDA/SCL scheme to configure 4 addresses per address pin.
- 27. TI's UCD9112 (http://focus.ti.com/docs/prod/folders/print/ucd9112.html) uses 2 ADC channels to select any valid 7-bit address.
- 28. Delvare, Jean (16 Aug 2005). "Re: [PATCH 4/5] add i2c\_probe\_device and i2c\_remove\_device" (https://lkml.org/lkml/2005/8/16/156). linux-kernel (Mailing list). <20050816183839.0eda95e3.khali@linux-fr.org>.
- 29. avr-libc: Example using the two-wire interface (TWI) (http://www.nongnu.org/avr-libc/user-manual/group\_\_twi\_\_demo.html).

# **Further reading**

- Mastering the I<sup>2</sup>C Bus; Vincent Himpe; 248 pages; 2011; ISBN 978-0-905705-98-9.
- The I2C Bus: From Theory to Practice; Dominique Paret; 314 pages; 1997; ISBN 978-0-471-96268-7.

### **External links**

- Official I2C specification (free) (http://www.nxp.com/documents/user\_manual/UM10204.pdf), NXP
- Detailed Introduction, Primer (http://www.i2c-bus.org)
- Using the I<sup>2</sup>C Bus with Linux (http://www.linuxjournal.com/article/1342)
- OpenBSD iic(4) manual page (http://www.openbsd.org/cgi-bin/man.cgi?query=iic&sektion=4)
- I<sup>2</sup>C Bus Technical Overview and Frequently Asked Questions (http://www.esacademy.com/faq/i2c/)
- Introduction to SPI and I2C protocols (http://www.byteparadigm.com/kb/article/AA-00255/22/Introduction-to-SPI-and-IC-protocols.html)

Retrieved from "https://en.wikipedia.org/w/index.php?title=I2C&oldid=806896539"

This page was last edited on 24 October 2017, at 20:34.

Text is available under the Creative Commons Attribution-ShareAlike License; additional terms may apply. By using this site, you agree to the <u>Terms of Use</u> and Privacy Policy. Wikipedia® is a registered trademark of the Wikimedia Foundation, Inc., a non-profit organization.